<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
    <title>列表渲染</title>
</head>
<!-- 
    key的内部原理
    虚拟dom的对象标识，数据发生变化，根据新数据生成新的虚拟dom
    新的虚拟dom 和 旧的虚拟dom 进行差异对比
    比较规则：
        旧dom内容改变了，生成新的真实dom，随后替换掉
        旧的dom内容没有改变，直接使用之前的真实dom
    index作为key的可能问题
        对数据进行逆序添加、逆序删除等破坏顺序的操作
            会产生没必要的真实dom更新 显示无误但是效率低下
        如果模板结构中包含输入类的dom
            产生错误的dom更新  显示错位等界面问题


 -->

<body>
    <div id="root">
        <h2>人员列表</h2>
        <!-- 效率低  -->
        <button @click.once="add">添加对象</button>
        <ul>
            <li v-for="(p,index) of persons" :key="p.id">
                <!-- 使用index作为key出现问题  输入框对应的值是错位的 -->
                <!-- <li v-for="(p,index) of persons" :key="index"> -->
                {{p.name}}-{{p.age}}
                <input type="text">
            </li>

        </ul>
    </div>

    <script>
        const vm = new Vue({
            el: "#root",
            data: {
                persons: [
                    { id: "002", name: "李四", age: 25 },
                    { id: "003", name: "王五", age: 20 },
                    { id: "001", name: "张三", age: 18 },

                ],

            },
            methods: {
                add() {
                    const p = { id: "004", name: "老刘", age: "35" }
                    this.persons.unshift(p)

                }
            }

        })
    </script>
</body>

</html>